<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>子组件向父组件传数据（自定义事件）</title>
</head>
<body>
  <!-- 父组件模板 -->
  <div id="app">
    <!-- v-on除了监听DOM事件，也可以监听组件间的自定义事件 -->
    <cpn @item-click="cpnclick"></cpn>
  </div>

  <!-- 子组件模板 -->
  <template id="cpn">
    <div>
      <button v-for="item of categories" @click="btnclick(item)"> {{item.name}} </button>
    </div>
  </template>

  <script src="../js/vue.js"></script>
  <script>
   
    // 子组件
    const cpn = { 
      template: '#cpn',
      data() {
        return {
          categories: [
            {id: 'aaa', name: '热门推荐'},
            {id: 'bbb', name: '手机数码'},
            {id: 'ccc', name: '家用家电'},
            {id: 'ddd', name: '电脑办公'}
          ]
        }
      },
      methods: {
        btnclick(item) {
          // 发射事件：自定义事件(自定义事件名称，自定义事件参数)
          // 自定义事件流程：1、在子组件中，通过$emit()来触发事件
          //                2、在父组件中，通过v-on来监听子组件事件
          this.$emit('item-click', item)

          // 要传多个参数时需放入一个数组中，监听到的是一个数组，用数组形式取出参数
          // this.$emit('item-click', [index,item]) 
        }
      }
    }

    // 父组件
    const app = new Vue({
      el: '#app',
      data: {
        
      },
      methods: {
        cpnclick(item) {
          console.log('cpnclick', item);
        }
      },
      components: {
        cpn: cpn
      }
    })

  </script>
</body>
</html>